<!DOCTYPE html>
<html lang="en-US">
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width,initial-scale=1">
    <title>集群部署 | Teng&#39;s blog</title>
    <meta name="generator" content="VuePress 1.9.7">
    <link rel="icon" href="/logo/favicon.ico">
    <meta name="description" content="">
    <meta name="keywords" content="大数据,java,h5,前端,人工智能,深度学习,go">
    <meta name="theme-color" content="#3eaf7c">
    
    <link rel="preload" href="/assets/css/0.styles.c17b3ac5.css" as="style"><link rel="preload" href="/assets/js/app.ab6a7ec7.js" as="script"><link rel="preload" href="/assets/js/2.bc9beebf.js" as="script"><link rel="preload" href="/assets/js/219.318a1817.js" as="script"><link rel="prefetch" href="/assets/js/10.829fbe09.js"><link rel="prefetch" href="/assets/js/100.21819a92.js"><link rel="prefetch" href="/assets/js/101.cba9a2fb.js"><link rel="prefetch" href="/assets/js/102.866a5b15.js"><link rel="prefetch" href="/assets/js/103.fdb7598a.js"><link rel="prefetch" href="/assets/js/104.75b80350.js"><link rel="prefetch" href="/assets/js/105.3030b5b8.js"><link rel="prefetch" href="/assets/js/106.11a5a8f2.js"><link rel="prefetch" href="/assets/js/107.232bdd92.js"><link rel="prefetch" href="/assets/js/108.a619d3d9.js"><link rel="prefetch" href="/assets/js/109.d31480d9.js"><link rel="prefetch" href="/assets/js/11.18a3d2d0.js"><link rel="prefetch" href="/assets/js/110.7b7051ad.js"><link rel="prefetch" href="/assets/js/111.6976153b.js"><link rel="prefetch" href="/assets/js/112.935a63bd.js"><link rel="prefetch" href="/assets/js/113.77296509.js"><link rel="prefetch" href="/assets/js/114.3ab3be4a.js"><link rel="prefetch" href="/assets/js/115.9b0dac10.js"><link rel="prefetch" href="/assets/js/116.55bc2cd6.js"><link rel="prefetch" href="/assets/js/117.75bd6d05.js"><link rel="prefetch" href="/assets/js/118.0dae142d.js"><link rel="prefetch" href="/assets/js/119.b1a2888c.js"><link rel="prefetch" href="/assets/js/12.81e292a4.js"><link rel="prefetch" href="/assets/js/120.6a3fd99f.js"><link rel="prefetch" href="/assets/js/121.ea1e1714.js"><link rel="prefetch" href="/assets/js/122.125ebe03.js"><link rel="prefetch" href="/assets/js/123.ec5bcef7.js"><link rel="prefetch" href="/assets/js/124.f346a2dc.js"><link rel="prefetch" href="/assets/js/125.11061d5a.js"><link rel="prefetch" href="/assets/js/126.7f8bc26b.js"><link rel="prefetch" href="/assets/js/127.26df99b6.js"><link rel="prefetch" href="/assets/js/128.0d4aae4f.js"><link rel="prefetch" href="/assets/js/129.ec01b50e.js"><link rel="prefetch" href="/assets/js/13.89c37359.js"><link rel="prefetch" href="/assets/js/130.9e570618.js"><link rel="prefetch" href="/assets/js/131.ffaed293.js"><link rel="prefetch" href="/assets/js/132.6ef77a2c.js"><link rel="prefetch" href="/assets/js/133.893078b6.js"><link rel="prefetch" href="/assets/js/134.a5229ebf.js"><link rel="prefetch" href="/assets/js/135.e1015261.js"><link rel="prefetch" href="/assets/js/136.655ac222.js"><link rel="prefetch" href="/assets/js/137.4c18a7dc.js"><link rel="prefetch" href="/assets/js/138.17cf92aa.js"><link rel="prefetch" href="/assets/js/139.7e23a82f.js"><link rel="prefetch" href="/assets/js/14.5a11397f.js"><link rel="prefetch" href="/assets/js/140.570f33f7.js"><link rel="prefetch" href="/assets/js/141.eb538cc8.js"><link rel="prefetch" href="/assets/js/142.2f38d42f.js"><link rel="prefetch" href="/assets/js/143.a32de735.js"><link rel="prefetch" href="/assets/js/144.76a63ee6.js"><link rel="prefetch" href="/assets/js/145.42483d13.js"><link rel="prefetch" href="/assets/js/146.068119e8.js"><link rel="prefetch" href="/assets/js/147.64de6f65.js"><link rel="prefetch" href="/assets/js/148.5709a561.js"><link rel="prefetch" href="/assets/js/149.9373f1d3.js"><link rel="prefetch" href="/assets/js/15.f98080cd.js"><link rel="prefetch" href="/assets/js/150.85328596.js"><link rel="prefetch" href="/assets/js/151.8179d926.js"><link rel="prefetch" href="/assets/js/152.357ef7ac.js"><link rel="prefetch" href="/assets/js/153.a7f37700.js"><link rel="prefetch" href="/assets/js/154.259e0731.js"><link rel="prefetch" href="/assets/js/155.609478f3.js"><link rel="prefetch" href="/assets/js/156.c02413b4.js"><link rel="prefetch" href="/assets/js/157.4225246d.js"><link rel="prefetch" href="/assets/js/158.90aa3193.js"><link rel="prefetch" href="/assets/js/159.48a36d7f.js"><link rel="prefetch" href="/assets/js/16.c2c39a12.js"><link rel="prefetch" href="/assets/js/160.1483c525.js"><link rel="prefetch" href="/assets/js/161.935da955.js"><link rel="prefetch" href="/assets/js/162.623fec51.js"><link rel="prefetch" href="/assets/js/163.9b588340.js"><link rel="prefetch" href="/assets/js/164.30ec5aba.js"><link rel="prefetch" href="/assets/js/165.189a8317.js"><link rel="prefetch" href="/assets/js/166.5af6c2ec.js"><link rel="prefetch" href="/assets/js/167.9dff1ac7.js"><link rel="prefetch" href="/assets/js/168.622f7001.js"><link rel="prefetch" href="/assets/js/169.2e7169b6.js"><link rel="prefetch" href="/assets/js/17.b69c805b.js"><link rel="prefetch" href="/assets/js/170.722cbe91.js"><link rel="prefetch" href="/assets/js/171.bc79c387.js"><link rel="prefetch" href="/assets/js/172.ee6817b8.js"><link rel="prefetch" href="/assets/js/173.b35d740e.js"><link rel="prefetch" href="/assets/js/174.5c6e7df5.js"><link rel="prefetch" href="/assets/js/175.d4a5903b.js"><link rel="prefetch" href="/assets/js/176.7be8b3ab.js"><link rel="prefetch" href="/assets/js/177.21a314f9.js"><link rel="prefetch" href="/assets/js/178.7c287ca3.js"><link rel="prefetch" href="/assets/js/179.b4682242.js"><link rel="prefetch" href="/assets/js/18.8b504010.js"><link rel="prefetch" href="/assets/js/180.0098b166.js"><link rel="prefetch" href="/assets/js/181.1ade00c6.js"><link rel="prefetch" href="/assets/js/182.2cdebd59.js"><link rel="prefetch" href="/assets/js/183.019718a7.js"><link rel="prefetch" href="/assets/js/184.d4ab9703.js"><link rel="prefetch" href="/assets/js/185.50d60e28.js"><link rel="prefetch" href="/assets/js/186.3a98e144.js"><link rel="prefetch" href="/assets/js/187.9ed4524b.js"><link rel="prefetch" href="/assets/js/188.c3a8a353.js"><link rel="prefetch" href="/assets/js/189.b949cdaa.js"><link rel="prefetch" href="/assets/js/19.6860ea74.js"><link rel="prefetch" href="/assets/js/190.7a54fb5e.js"><link rel="prefetch" href="/assets/js/191.804d06a5.js"><link rel="prefetch" href="/assets/js/192.c729ba9b.js"><link rel="prefetch" href="/assets/js/193.e8d492ad.js"><link rel="prefetch" href="/assets/js/194.49b4668e.js"><link rel="prefetch" href="/assets/js/195.e4508c24.js"><link rel="prefetch" href="/assets/js/196.538420c6.js"><link rel="prefetch" href="/assets/js/197.56fda656.js"><link rel="prefetch" href="/assets/js/198.75e420ad.js"><link rel="prefetch" href="/assets/js/199.67784aef.js"><link rel="prefetch" href="/assets/js/20.82f2e898.js"><link rel="prefetch" href="/assets/js/200.b32cd750.js"><link rel="prefetch" href="/assets/js/201.594db75b.js"><link rel="prefetch" href="/assets/js/202.70b380ec.js"><link rel="prefetch" href="/assets/js/203.0de30338.js"><link rel="prefetch" href="/assets/js/204.360c28c7.js"><link rel="prefetch" href="/assets/js/205.5b4b553b.js"><link rel="prefetch" href="/assets/js/206.6bd13fc8.js"><link rel="prefetch" href="/assets/js/207.875be01b.js"><link rel="prefetch" href="/assets/js/208.00694e2b.js"><link rel="prefetch" href="/assets/js/209.1fa15603.js"><link rel="prefetch" href="/assets/js/21.3f050c1d.js"><link rel="prefetch" href="/assets/js/210.f11e4fe3.js"><link rel="prefetch" href="/assets/js/211.a9beca8a.js"><link rel="prefetch" href="/assets/js/212.2fb3a3b1.js"><link rel="prefetch" href="/assets/js/213.c2fb7dcf.js"><link rel="prefetch" href="/assets/js/214.7613f2f7.js"><link rel="prefetch" href="/assets/js/215.ac00cd4b.js"><link rel="prefetch" href="/assets/js/216.926eb535.js"><link rel="prefetch" href="/assets/js/217.e03af99a.js"><link rel="prefetch" href="/assets/js/218.0212a1a9.js"><link rel="prefetch" href="/assets/js/22.f2a18e55.js"><link rel="prefetch" href="/assets/js/220.34f368ec.js"><link rel="prefetch" href="/assets/js/221.1d325330.js"><link rel="prefetch" href="/assets/js/222.f8ac9e1e.js"><link rel="prefetch" href="/assets/js/223.1d081b10.js"><link rel="prefetch" href="/assets/js/224.d4a3c833.js"><link rel="prefetch" href="/assets/js/225.86046773.js"><link rel="prefetch" href="/assets/js/226.ee01e5ed.js"><link rel="prefetch" href="/assets/js/227.cc700349.js"><link rel="prefetch" href="/assets/js/228.121d2708.js"><link rel="prefetch" href="/assets/js/229.411a1a59.js"><link rel="prefetch" href="/assets/js/23.8416a606.js"><link rel="prefetch" href="/assets/js/230.ce1cd57d.js"><link rel="prefetch" href="/assets/js/231.9e415c00.js"><link rel="prefetch" href="/assets/js/232.af1434b0.js"><link rel="prefetch" href="/assets/js/233.aedf0a69.js"><link rel="prefetch" href="/assets/js/234.7343179f.js"><link rel="prefetch" href="/assets/js/235.3ea94188.js"><link rel="prefetch" href="/assets/js/236.e632719a.js"><link rel="prefetch" href="/assets/js/237.34a70a59.js"><link rel="prefetch" href="/assets/js/238.9582b4be.js"><link rel="prefetch" href="/assets/js/239.2a1f2f8d.js"><link rel="prefetch" href="/assets/js/24.73629fb4.js"><link rel="prefetch" href="/assets/js/240.e0563eb9.js"><link rel="prefetch" href="/assets/js/241.7a2b4d6e.js"><link rel="prefetch" href="/assets/js/242.f9f59053.js"><link rel="prefetch" href="/assets/js/243.95904034.js"><link rel="prefetch" href="/assets/js/244.0c91ecaa.js"><link rel="prefetch" href="/assets/js/245.58988353.js"><link rel="prefetch" href="/assets/js/246.73360878.js"><link rel="prefetch" href="/assets/js/247.3f36cb13.js"><link rel="prefetch" href="/assets/js/248.9bca99ac.js"><link rel="prefetch" href="/assets/js/249.e78a3dbb.js"><link rel="prefetch" href="/assets/js/25.f62ba06b.js"><link rel="prefetch" href="/assets/js/250.5999a7b3.js"><link rel="prefetch" href="/assets/js/251.5204362e.js"><link rel="prefetch" href="/assets/js/252.a731f0e2.js"><link rel="prefetch" href="/assets/js/253.ef15afff.js"><link rel="prefetch" href="/assets/js/254.8e0d8aa8.js"><link rel="prefetch" href="/assets/js/255.53408731.js"><link rel="prefetch" href="/assets/js/256.3d08ae8f.js"><link rel="prefetch" href="/assets/js/257.1de6306c.js"><link rel="prefetch" href="/assets/js/258.b3ec2e6c.js"><link rel="prefetch" href="/assets/js/259.40e6c088.js"><link rel="prefetch" href="/assets/js/26.ed3d7d52.js"><link rel="prefetch" href="/assets/js/260.05ea317d.js"><link rel="prefetch" href="/assets/js/261.048af235.js"><link rel="prefetch" href="/assets/js/262.905ce2e2.js"><link rel="prefetch" href="/assets/js/263.8ace396b.js"><link rel="prefetch" href="/assets/js/264.10841fe2.js"><link rel="prefetch" href="/assets/js/265.f94f5548.js"><link rel="prefetch" href="/assets/js/266.bf7b6e06.js"><link rel="prefetch" href="/assets/js/267.4c03cbf4.js"><link rel="prefetch" href="/assets/js/268.1886e607.js"><link rel="prefetch" href="/assets/js/269.9dfca98b.js"><link rel="prefetch" href="/assets/js/27.18a2fe1c.js"><link rel="prefetch" href="/assets/js/270.a0ebdd62.js"><link rel="prefetch" href="/assets/js/271.cb9ce68b.js"><link rel="prefetch" href="/assets/js/272.99ea7c05.js"><link rel="prefetch" href="/assets/js/273.7f5c9d16.js"><link rel="prefetch" href="/assets/js/274.1ca50474.js"><link rel="prefetch" href="/assets/js/275.e0a79a93.js"><link rel="prefetch" href="/assets/js/276.5e9f441d.js"><link rel="prefetch" href="/assets/js/277.31f82a4b.js"><link rel="prefetch" href="/assets/js/278.2df5557a.js"><link rel="prefetch" href="/assets/js/279.6caef400.js"><link rel="prefetch" href="/assets/js/28.30687ae2.js"><link rel="prefetch" href="/assets/js/280.07da039a.js"><link rel="prefetch" href="/assets/js/281.81b66752.js"><link rel="prefetch" href="/assets/js/282.a362880b.js"><link rel="prefetch" href="/assets/js/283.37de8db2.js"><link rel="prefetch" href="/assets/js/284.31a9bcd5.js"><link rel="prefetch" href="/assets/js/285.e1ed9d70.js"><link rel="prefetch" href="/assets/js/286.5cd73851.js"><link rel="prefetch" href="/assets/js/287.b598b99a.js"><link rel="prefetch" href="/assets/js/288.a2580005.js"><link rel="prefetch" href="/assets/js/289.83413eb3.js"><link rel="prefetch" href="/assets/js/29.8f48fd0e.js"><link rel="prefetch" href="/assets/js/290.405974a0.js"><link rel="prefetch" href="/assets/js/291.f762f6f9.js"><link rel="prefetch" href="/assets/js/292.f5851afc.js"><link rel="prefetch" href="/assets/js/293.8e7d9ffa.js"><link rel="prefetch" href="/assets/js/294.3694f780.js"><link rel="prefetch" href="/assets/js/295.84d9cd4c.js"><link rel="prefetch" href="/assets/js/296.0a6bbe5d.js"><link rel="prefetch" href="/assets/js/297.195f8ede.js"><link rel="prefetch" href="/assets/js/3.7494bd83.js"><link rel="prefetch" href="/assets/js/30.5f000d59.js"><link rel="prefetch" href="/assets/js/31.2f3aea00.js"><link rel="prefetch" href="/assets/js/32.78912726.js"><link rel="prefetch" href="/assets/js/33.4f600444.js"><link rel="prefetch" href="/assets/js/34.1ec8259c.js"><link rel="prefetch" href="/assets/js/35.bc414639.js"><link rel="prefetch" href="/assets/js/36.b0c05f62.js"><link rel="prefetch" href="/assets/js/37.7e626d70.js"><link rel="prefetch" href="/assets/js/38.bb3a6a22.js"><link rel="prefetch" href="/assets/js/39.3d17059f.js"><link rel="prefetch" href="/assets/js/4.ff6020d1.js"><link rel="prefetch" href="/assets/js/40.2023aaeb.js"><link rel="prefetch" href="/assets/js/41.64452f22.js"><link rel="prefetch" href="/assets/js/42.32522c9c.js"><link rel="prefetch" href="/assets/js/43.ae24bdff.js"><link rel="prefetch" href="/assets/js/44.3acc6c82.js"><link rel="prefetch" href="/assets/js/45.2cec263d.js"><link rel="prefetch" href="/assets/js/46.ceacfcd8.js"><link rel="prefetch" href="/assets/js/47.59030139.js"><link rel="prefetch" href="/assets/js/48.fa5e3c59.js"><link rel="prefetch" href="/assets/js/49.2054398b.js"><link rel="prefetch" href="/assets/js/5.f2ade644.js"><link rel="prefetch" href="/assets/js/50.47a76469.js"><link rel="prefetch" href="/assets/js/51.c36ce30b.js"><link rel="prefetch" href="/assets/js/52.72ce6650.js"><link rel="prefetch" href="/assets/js/53.9dbe65dd.js"><link rel="prefetch" href="/assets/js/54.b571c195.js"><link rel="prefetch" href="/assets/js/55.3502ffd5.js"><link rel="prefetch" href="/assets/js/56.790119c4.js"><link rel="prefetch" href="/assets/js/57.aae4081b.js"><link rel="prefetch" href="/assets/js/58.e54d1920.js"><link rel="prefetch" href="/assets/js/59.6eaa8c48.js"><link rel="prefetch" href="/assets/js/6.04d544f0.js"><link rel="prefetch" href="/assets/js/60.7b2d3e47.js"><link rel="prefetch" href="/assets/js/61.093542b8.js"><link rel="prefetch" href="/assets/js/62.d0af83fd.js"><link rel="prefetch" href="/assets/js/63.b57f13fb.js"><link rel="prefetch" href="/assets/js/64.acbb2295.js"><link rel="prefetch" href="/assets/js/65.87d05864.js"><link rel="prefetch" href="/assets/js/66.773a0404.js"><link rel="prefetch" href="/assets/js/67.c66984d0.js"><link rel="prefetch" href="/assets/js/68.77bfcb54.js"><link rel="prefetch" href="/assets/js/69.7e3d1cc4.js"><link rel="prefetch" href="/assets/js/7.bc46b052.js"><link rel="prefetch" href="/assets/js/70.dbd5eb9b.js"><link rel="prefetch" href="/assets/js/71.109923c3.js"><link rel="prefetch" href="/assets/js/72.c92d7f25.js"><link rel="prefetch" href="/assets/js/73.a8ef2055.js"><link rel="prefetch" href="/assets/js/74.79119a72.js"><link rel="prefetch" href="/assets/js/75.009bcb5e.js"><link rel="prefetch" href="/assets/js/76.cba94ffd.js"><link rel="prefetch" href="/assets/js/77.caa07e47.js"><link rel="prefetch" href="/assets/js/78.fef64e9e.js"><link rel="prefetch" href="/assets/js/79.72d6eb81.js"><link rel="prefetch" href="/assets/js/8.8cf6541b.js"><link rel="prefetch" href="/assets/js/80.9370a1bd.js"><link rel="prefetch" href="/assets/js/81.f53b6c0a.js"><link rel="prefetch" href="/assets/js/82.01861305.js"><link rel="prefetch" href="/assets/js/83.4d69c6c5.js"><link rel="prefetch" href="/assets/js/84.ea80ae96.js"><link rel="prefetch" href="/assets/js/85.34c10294.js"><link rel="prefetch" href="/assets/js/86.4c7d6d58.js"><link rel="prefetch" href="/assets/js/87.ade6c1ee.js"><link rel="prefetch" href="/assets/js/88.306bb690.js"><link rel="prefetch" href="/assets/js/89.ed02954c.js"><link rel="prefetch" href="/assets/js/9.b3d99320.js"><link rel="prefetch" href="/assets/js/90.8db20502.js"><link rel="prefetch" href="/assets/js/91.3d01b6a4.js"><link rel="prefetch" href="/assets/js/92.b3dcea87.js"><link rel="prefetch" href="/assets/js/93.28790aa5.js"><link rel="prefetch" href="/assets/js/94.45722d7d.js"><link rel="prefetch" href="/assets/js/95.c04b6585.js"><link rel="prefetch" href="/assets/js/96.7c4d9328.js"><link rel="prefetch" href="/assets/js/97.85bb6089.js"><link rel="prefetch" href="/assets/js/98.e22a9c08.js"><link rel="prefetch" href="/assets/js/99.fd9f1f1d.js">
    <link rel="stylesheet" href="/assets/css/0.styles.c17b3ac5.css">
  </head>
  <body class="theme-mode-light">
    <div id="app" data-server-rendered="true"><div class="theme-container sidebar-open have-rightmenu"><header class="navbar blur"><div title="目录" class="sidebar-button"><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" role="img" viewBox="0 0 448 512" class="icon"><path fill="currentColor" d="M436 124H12c-6.627 0-12-5.373-12-12V80c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12z"></path></svg></div> <a href="/" class="home-link router-link-active"><img src="/logo/TB-mini.png" alt="Teng's blog" class="logo"> <span class="site-name can-hide">Teng's blog</span></a> <div class="links"><div class="search-box"><input aria-label="Search" autocomplete="off" spellcheck="false" value=""> <!----></div> <nav class="nav-links can-hide"><div class="nav-item"><a href="/" class="nav-link">首页</a></div><div class="nav-item"><a href="/note/java/" class="nav-link">Java</a></div><div class="nav-item"><a href="/note/font-end/" class="nav-link">H5前端</a></div> <a href="https://github.com/shetengteng" target="_blank" rel="noopener noreferrer" class="repo-link">
    GitHub
    <span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></nav></div></header> <div class="sidebar-mask"></div> <div class="sidebar-hover-trigger"></div> <aside class="sidebar" style="display:none;"><!----> <nav class="nav-links"><div class="nav-item"><a href="/" class="nav-link">首页</a></div><div class="nav-item"><a href="/note/java/" class="nav-link">Java</a></div><div class="nav-item"><a href="/note/font-end/" class="nav-link">H5前端</a></div> <a href="https://github.com/shetengteng" target="_blank" rel="noopener noreferrer" class="repo-link">
    GitHub
    <span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></nav>  <ul class="sidebar-links"><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading open"><span>入门</span> <span class="arrow down"></span></p> <ul class="sidebar-links sidebar-group-items"><li><a href="/pages/b70965/" class="sidebar-link">概述</a></li><li><a href="/pages/023eda/" aria-current="page" class="active sidebar-link">集群部署</a><ul class="sidebar-sub-headers"><li class="sidebar-sub-header"><a href="/pages/023eda/#集群规划" class="sidebar-link">集群规划</a></li><li class="sidebar-sub-header"><a href="/pages/023eda/#下载地址" class="sidebar-link">下载地址</a></li><li class="sidebar-sub-header"><a href="/pages/023eda/#kafka部署与配置" class="sidebar-link">kafka部署与配置</a></li><li class="sidebar-sub-header"><a href="/pages/023eda/#kafka目录构成" class="sidebar-link">kafka目录构成</a></li><li class="sidebar-sub-header"><a href="/pages/023eda/#kafka环境变量" class="sidebar-link">kafka环境变量</a></li><li class="sidebar-sub-header"><a href="/pages/023eda/#安装zookeeper" class="sidebar-link">安装Zookeeper</a></li><li class="sidebar-sub-header"><a href="/pages/023eda/#启动zookeeper集群" class="sidebar-link">启动zookeeper集群</a></li><li class="sidebar-sub-header"><a href="/pages/023eda/#启动kafka集群" class="sidebar-link">启动kafka集群</a></li><li class="sidebar-sub-header"><a href="/pages/023eda/#kafka群起脚本" class="sidebar-link">kafka群起脚本</a><ul class="sidebar-sub-headers"><li class="sidebar-sub-header"><a href="/pages/023eda/#写法1" class="sidebar-link">写法1</a></li><li class="sidebar-sub-header"><a href="/pages/023eda/#写法2" class="sidebar-link">写法2</a></li></ul></li></ul></li><li><a href="/pages/22aea2/" class="sidebar-link">命令操作</a></li><li><section class="sidebar-group collapsable is-sub-group depth-1"><p class="sidebar-heading"><span>生产者</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable is-sub-group depth-1"><p class="sidebar-heading"><span>Broker</span> <span class="arrow right"></span></p> <!----></section></li></ul></section></li></ul> </aside> <div><main class="page"><div class="theme-vdoing-wrapper "><div class="articleInfo-wrap" data-v-0c557b5e><div class="articleInfo" data-v-0c557b5e><ul class="breadcrumbs" data-v-0c557b5e><li data-v-0c557b5e><a href="/" title="首页" class="iconfont icon-home router-link-active" data-v-0c557b5e></a></li> <li data-v-0c557b5e><span data-v-0c557b5e>Middleware-Kafka</span></li><li data-v-0c557b5e><span data-v-0c557b5e>入门</span></li></ul> <div class="info" data-v-0c557b5e><div title="作者" class="author iconfont icon-touxiang" data-v-0c557b5e><a href="https://github.com/shetengteng" target="_blank" title="作者" class="beLink" data-v-0c557b5e>Shetengteng</a></div> <div title="创建时间" class="date iconfont icon-riqi" data-v-0c557b5e><a href="javascript:;" data-v-0c557b5e>2022-04-07</a></div> <!----></div></div></div> <!----> <div class="content-wrapper"><div class="right-menu-wrapper"><div class="right-menu-margin"><div class="right-menu-content"></div></div></div> <h1><!---->集群部署<!----></h1>  <div class="theme-vdoing-content content__default"><p>// todo xxx linux 参考</p> <h2 id="集群规划"><a href="#集群规划" class="header-anchor">#</a> 集群规划</h2> <p>linux100，以及linux101和linux102分别表示3台虚拟机</p> <table><thead><tr><th>linux101</th> <th>linux102</th> <th>linux103</th></tr></thead> <tbody><tr><td>zk</td> <td>zk</td> <td>zk</td></tr> <tr><td>kafka</td> <td>kafka</td> <td>kafka</td></tr></tbody></table> <p>注意：每台服务器都需要关闭防火墙，针对Centos7有如下命令</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code>systemctl stop firewalld
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><h2 id="下载地址"><a href="#下载地址" class="header-anchor">#</a> 下载地址</h2> <p>官方下载地址</p> <p>http://kafka.apache.org/downloads.html</p> <p>本次使用的版本地址</p> <p>https://archive.apache.org/dist/kafka/3.0.0/kafka_2.12-3.0.0.tgz</p> <h2 id="kafka部署与配置"><a href="#kafka部署与配置" class="header-anchor">#</a> kafka部署与配置</h2> <blockquote><p>在linux101，linux102，linux103都进行如下操作，注意：broker.id需要配置不同的值</p></blockquote> <p>下载</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 opt<span class="token punctuation">]</span><span class="token comment"># wget https://archive.apache.org/dist/kafka/3.0.0/kafka_2.12-3.0.0.tgz</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>kafka_2.12-3.0.0.tgz名称解析</p> <ul><li>2.12是scala的版本</li> <li>3.0.0是kafka版本</li></ul> <p>解压后修改名称</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 opt<span class="token punctuation">]</span><span class="token comment"># tar -zxvf kafka_2.12-3.0.0.tgz -C /opt/module/</span>
<span class="token punctuation">[</span>root@linux101 opt<span class="token punctuation">]</span><span class="token comment"># cd module/</span>
<span class="token punctuation">[</span>root@linux101 module<span class="token punctuation">]</span><span class="token comment"># mv kafka_2.12-3.0.0/ kafka</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br></div></div><p>进入/opt/module/kafka，修改配置文件</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 module<span class="token punctuation">]</span><span class="token comment"># cd kafka/config/</span>
<span class="token punctuation">[</span>root@linux101 config<span class="token punctuation">]</span><span class="token comment"># vim server.properties </span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br></div></div><p>配置内容如下</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token comment"># 注意配置点</span>
<span class="token comment"># broker 的全局唯一编号，不能重复，只能是数字 </span>
broker.id<span class="token operator">=</span><span class="token number">0</span>

<span class="token comment">#处理网络请求的线程数量</span>
num.network.threads<span class="token operator">=</span><span class="token number">3</span>
<span class="token comment">#用来处理磁盘 IO 的线程数量</span>
num.io.threads<span class="token operator">=</span><span class="token number">8</span>
<span class="token comment">#发送套接字的缓冲区大小</span>
socket.send.buffer.bytes<span class="token operator">=</span><span class="token number">102400</span>
<span class="token comment">#接收套接字的缓冲区大小</span>
socket.receive.buffer.bytes<span class="token operator">=</span><span class="token number">102400</span>
<span class="token comment">#请求套接字的缓冲区大小</span>
socket.request.max.bytes<span class="token operator">=</span><span class="token number">104857600</span>

<span class="token comment"># 注意配置点</span>
<span class="token comment"># kafka 运行日志(数据)存放的路径，路径不需要提前创建，kafka 自动帮你创建，可以配置多个磁盘路径，路径与路径之间可以用&quot;，&quot;分隔</span>
log.dirs<span class="token operator">=</span>/opt/module/kafka/datas

<span class="token comment">#topic 在当前 broker 上的分区个数</span>
num.partitions<span class="token operator">=</span><span class="token number">1</span>
<span class="token comment">#用来恢复和清理 data 下数据的线程数量</span>
num.recovery.threads.per.data.dir<span class="token operator">=</span><span class="token number">1</span>
<span class="token comment"># 每个 topic 创建时的副本数，默认时 1 个副本</span>
offsets.topic.replication.factor<span class="token operator">=</span><span class="token number">1</span>
<span class="token comment">#segment 文件保留的最长时间，超时将被删除</span>
log.retention.hours<span class="token operator">=</span><span class="token number">168</span>
<span class="token comment">#每个 segment 文件的大小，默认最大 1G</span>
log.segment.bytes<span class="token operator">=</span><span class="token number">1073741824</span>
<span class="token comment"># 检查过期数据的时间，默认 5 分钟检查一次是否数据过期</span>
log.retention.check.interval.ms<span class="token operator">=</span><span class="token number">300000</span>

<span class="token comment"># 注意配置点</span>
<span class="token comment"># 配置连接 Zookeeper 集群地址（在zk根目录下创建/kafka方便管理，否则会在默认的目录下配置会分散）</span>
zookeeper.connect<span class="token operator">=</span>linux101:2181,linux102:2181,linux103:2181/kafka
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br><span class="line-number">17</span><br><span class="line-number">18</span><br><span class="line-number">19</span><br><span class="line-number">20</span><br><span class="line-number">21</span><br><span class="line-number">22</span><br><span class="line-number">23</span><br><span class="line-number">24</span><br><span class="line-number">25</span><br><span class="line-number">26</span><br><span class="line-number">27</span><br><span class="line-number">28</span><br><span class="line-number">29</span><br><span class="line-number">30</span><br><span class="line-number">31</span><br><span class="line-number">32</span><br><span class="line-number">33</span><br><span class="line-number">34</span><br><span class="line-number">35</span><br></div></div><h2 id="kafka目录构成"><a href="#kafka目录构成" class="header-anchor">#</a> kafka目录构成</h2> <p>进入kafka目录</p> <ul><li>bin存储命令</li> <li>config存储配置文件</li> <li>libs存储第三方依赖</li></ul> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 kafka<span class="token punctuation">]</span><span class="token comment"># ll</span>
总用量 <span class="token number">64</span>
drwxr-xr-x. <span class="token number">3</span> root root  <span class="token number">4096</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> bin
drwxr-xr-x. <span class="token number">3</span> root root  <span class="token number">4096</span> <span class="token number">4</span>月   <span class="token number">8</span> <span class="token number">16</span>:43 config
drwxr-xr-x. <span class="token number">2</span> root root  <span class="token number">4096</span> <span class="token number">4</span>月   <span class="token number">8</span> <span class="token number">16</span>:37 libs
-rw-r--r--. <span class="token number">1</span> root root <span class="token number">14521</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> LICENSE
drwxr-xr-x. <span class="token number">2</span> root root  <span class="token number">4096</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> licenses
-rw-r--r--. <span class="token number">1</span> root root <span class="token number">28184</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> NOTICE
drwxr-xr-x. <span class="token number">2</span> root root  <span class="token number">4096</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> site-docs
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br></div></div><p>进入bin目录，重点关注如下命令，分别是关于服务启停，生产者消费者，topic管理等</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 bin<span class="token punctuation">]</span><span class="token comment"># ll</span>
总用量 <span class="token number">160</span>
<span class="token punctuation">..</span>.
-rwxr-xr-x. <span class="token number">1</span> root root   <span class="token number">945</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> kafka-console-consumer.sh
-rwxr-xr-x. <span class="token number">1</span> root root   <span class="token number">944</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> kafka-console-producer.sh
<span class="token punctuation">..</span>.
-rwxr-xr-x. <span class="token number">1</span> root root  <span class="token number">1376</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> kafka-server-start.sh
-rwxr-xr-x. <span class="token number">1</span> root root  <span class="token number">1361</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> kafka-server-stop.sh
<span class="token punctuation">..</span>.
-rwxr-xr-x. <span class="token number">1</span> root root   <span class="token number">863</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> kafka-topics.sh
<span class="token punctuation">..</span>.
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br></div></div><p>进入config目录，主要关注的是 server.properties 的配置</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 config<span class="token punctuation">]</span><span class="token comment"># ll</span>
总用量 <span class="token number">76</span>
-rw-r--r--. <span class="token number">1</span> root root  <span class="token number">906</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> connect-console-sink.properties
-rw-r--r--. <span class="token number">1</span> root root  <span class="token number">909</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> connect-console-source.properties
-rw-r--r--. <span class="token number">1</span> root root <span class="token number">5475</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> connect-distributed.properties
-rw-r--r--. <span class="token number">1</span> root root  <span class="token number">883</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> connect-file-sink.properties
-rw-r--r--. <span class="token number">1</span> root root  <span class="token number">881</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> connect-file-source.properties
-rw-r--r--. <span class="token number">1</span> root root <span class="token number">2103</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> connect-log4j.properties
-rw-r--r--. <span class="token number">1</span> root root <span class="token number">2540</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> connect-mirror-maker.properties
-rw-r--r--. <span class="token number">1</span> root root <span class="token number">2262</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> connect-standalone.properties
-rw-r--r--. <span class="token number">1</span> root root <span class="token number">1221</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> consumer.properties
drwxr-xr-x. <span class="token number">2</span> root root <span class="token number">4096</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> kraft
-rw-r--r--. <span class="token number">1</span> root root <span class="token number">4674</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> log4j.properties
-rw-r--r--. <span class="token number">1</span> root root <span class="token number">1925</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> producer.properties
-rw-r--r--. <span class="token number">1</span> root root <span class="token number">6890</span> <span class="token number">4</span>月   <span class="token number">8</span> <span class="token number">16</span>:43 server.properties
-rw-r--r--. <span class="token number">1</span> root root <span class="token number">1032</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> tools-log4j.properties
-rw-r--r--. <span class="token number">1</span> root root <span class="token number">1169</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> trogdor.conf
-rw-r--r--. <span class="token number">1</span> root root <span class="token number">1205</span> <span class="token number">9</span>月   <span class="token number">9</span> <span class="token number">2021</span> zookeeper.properties
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br><span class="line-number">17</span><br><span class="line-number">18</span><br></div></div><h2 id="kafka环境变量"><a href="#kafka环境变量" class="header-anchor">#</a> kafka环境变量</h2> <blockquote><p>在linux101，linux102，linux103都配置上kafka的环境变量</p></blockquote> <p>在/etc/profile.d/kafka.sh 文件中增加 kafka环境变量配置</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 config<span class="token punctuation">]</span><span class="token comment"># vim /etc/profile.d/kafka.sh</span>

<span class="token comment">#KAFKA_HOME</span>
<span class="token builtin class-name">export</span> <span class="token assign-left variable">KAFKA_HOME</span><span class="token operator">=</span>/opt/module/kafka
<span class="token builtin class-name">export</span> <span class="token assign-left variable"><span class="token environment constant">PATH</span></span><span class="token operator">=</span><span class="token environment constant">$PATH</span><span class="token builtin class-name">:</span><span class="token variable">$KAFKA_HOME</span>/bin
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br></div></div><p>刷新一下环境变量</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 config<span class="token punctuation">]</span><span class="token comment"># source /etc/profile</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><h2 id="安装zookeeper"><a href="#安装zookeeper" class="header-anchor">#</a> 安装Zookeeper</h2> <blockquote><p>在linux101，linux102，linux103 都进行如下操作，安装Zookeeper集群</p></blockquote> <p>官网： https://zookeeper.apache.org/</p> <p>下载地址：https://dlcdn.apache.org/zookeeper/zookeeper-3.5.9/apache-zookeeper-3.5.9-bin.tar.gz</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 opt<span class="token punctuation">]</span><span class="token comment"># wget https://dlcdn.apache.org/zookeeper/zookeeper-3.5.9/apache-zookeeper-3.5.9-bin.tar.gz --no-check-certificate</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>解压并重命名</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 opt<span class="token punctuation">]</span><span class="token comment"># tar -zvxf apache-zookeeper-3.5.9-bin.tar.gz -C /opt/module/</span>
<span class="token punctuation">[</span>root@linux101 opt<span class="token punctuation">]</span><span class="token comment"># cd module/</span>
<span class="token punctuation">[</span>root@linux101 module<span class="token punctuation">]</span><span class="token comment"># mv apache-zookeeper-3.5.9-bin/ zookeeper</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br></div></div><p>在/opt/module/zookeeper/这个目录下创建zkData；并在zkData目录下创建一个myid的文件</p> <ul><li>linux101输入1，linux102输入2，linux103输入3</li></ul> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 zookeeper<span class="token punctuation">]</span><span class="token comment"># mkdir zkData</span>
<span class="token punctuation">[</span>root@linux101 zookeeper<span class="token punctuation">]</span><span class="token comment"># cd zkData</span>
<span class="token punctuation">[</span>root@linux101 zkData<span class="token punctuation">]</span><span class="token comment"># vim myid</span>
<span class="token comment"># 输入</span>
<span class="token number">1</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br></div></div><p>修改配置：拷贝/opt/module/zookeeper/conf这个目录下的zoo_sample.cfg为zoo.cfg</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 conf<span class="token punctuation">]</span><span class="token comment"># cp zoo_sample.cfg zoo.cfg</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>打开zoo.cfg文件，修改数据存储路径配置</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 conf<span class="token punctuation">]</span>$ <span class="token function">vim</span> zoo.cfg
<span class="token comment"># 修改 </span>
<span class="token assign-left variable">dataDir</span><span class="token operator">=</span>/opt/module/zookeeper/zkData/
<span class="token comment"># 增加</span>
<span class="token comment">#######################cluster##########################</span>
server.1<span class="token operator">=</span>linux101:2888:3888
server.2<span class="token operator">=</span>linux102:2888:3888
server.3<span class="token operator">=</span>linux103:2888:3888
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br></div></div><p>其他服务器也执行上述操作即可
注意：<strong>如果没有关闭服务器的防火墙，可能会导致zk集群启动失败</strong></p> <h2 id="启动zookeeper集群"><a href="#启动zookeeper集群" class="header-anchor">#</a> 启动zookeeper集群</h2> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 module<span class="token punctuation">]</span><span class="token comment"># /opt/module/zookeeper/bin/zkServer.sh start</span>
<span class="token punctuation">[</span>root@linux102 module<span class="token punctuation">]</span><span class="token comment"># /opt/module/zookeeper/bin/zkServer.sh start</span>
<span class="token punctuation">[</span>root@linux103 module<span class="token punctuation">]</span><span class="token comment"># /opt/module/zookeeper/bin/zkServer.sh start</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br></div></div><p>查看启动情况：QuorumPeerMain进程都启动说明集群启动完成</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 module<span class="token punctuation">]</span><span class="token comment"># jps</span>
<span class="token number">30845</span> QuorumPeerMain
<span class="token number">31103</span> Jps
<span class="token punctuation">[</span>root@linux102 zkData<span class="token punctuation">]</span><span class="token comment"># jps</span>
<span class="token number">118417</span> Jps
<span class="token number">118177</span> QuorumPeerMain
<span class="token punctuation">[</span>root@linux103 zkData<span class="token punctuation">]</span><span class="token comment"># jps</span>
<span class="token number">121274</span> Jps
<span class="token number">121164</span> QuorumPeerMain
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br></div></div><p>查看状态</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 bin<span class="token punctuation">]</span><span class="token comment"># ./zkServer.sh status</span>
ZooKeeper JMX enabled by default
Using config: /opt/module/zookeeper/bin/<span class="token punctuation">..</span>/conf/zoo.cfg
Client port found: <span class="token number">2181</span>. Client address: localhost. Client SSL: false.
Mode: follower

<span class="token punctuation">[</span>root@linux102 bin<span class="token punctuation">]</span><span class="token comment"># ./zkServer.sh status</span>
ZooKeeper JMX enabled by default
Using config: /opt/module/zookeeper/bin/<span class="token punctuation">..</span>/conf/zoo.cfg
Client port found: <span class="token number">2181</span>. Client address: localhost. Client SSL: false.
Mode: leader

<span class="token punctuation">[</span>root@linux103 bin<span class="token punctuation">]</span><span class="token comment"># ./zkServer.sh status</span>
ZooKeeper JMX enabled by default
Using config: /opt/module/zookeeper/bin/<span class="token punctuation">..</span>/conf/zoo.cfg
Client port found: <span class="token number">2181</span>. Client address: localhost. Client SSL: false.
Mode: follower
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br><span class="line-number">17</span><br></div></div><p>其他：如果要关闭集群需要每台虚拟机上执行</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code>/opt/module/zookeeper/bin/zkServer.sh stop
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><h2 id="启动kafka集群"><a href="#启动kafka集群" class="header-anchor">#</a> 启动kafka集群</h2> <blockquote><p>依次在linux101,linux102,linux103上启动kafka</p></blockquote> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 kafka<span class="token punctuation">]</span><span class="token comment"># pwd</span>
/opt/module/kafka

<span class="token punctuation">[</span>root@linux101 kafka<span class="token punctuation">]</span><span class="token comment"># bin/kafka-server-start.sh -daemon config/server.properties</span>
<span class="token punctuation">[</span>root@linux102 kafka<span class="token punctuation">]</span><span class="token comment"># bin/kafka-server-start.sh -daemon config/server.properties</span>
<span class="token punctuation">[</span>root@linux103 kafka<span class="token punctuation">]</span><span class="token comment"># bin/kafka-server-start.sh -daemon config/server.properties</span>
<span class="token comment"># 表示后台启动，使用server.properties覆盖文件</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br></div></div><p>注意：配置文件的路径要求能读取到 server.properties</p> <p>查看启动状态</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux103 kafka<span class="token punctuation">]</span><span class="token comment"># jps</span>
<span class="token number">89773</span> QuorumPeerMain
<span class="token number">101597</span> Jps
<span class="token number">98364</span> Kafka
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br></div></div><p>关闭集群相关命令</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 kafka<span class="token punctuation">]</span><span class="token comment"># bin/kafka-server-stop.sh</span>
<span class="token punctuation">[</span>root@linux102 kafka<span class="token punctuation">]</span><span class="token comment"># bin/kafka-server-stop.sh</span>
<span class="token punctuation">[</span>root@linux103 kafka<span class="token punctuation">]</span><span class="token comment"># bin/kafka-server-stop.sh</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br></div></div><p>注意</p> <ul><li>停止 Kafka 集群时，一定要等 Kafka 所有节点进程全部停止后再停止 Zookeeper集群</li> <li>Zookeeper 集群当中记录着 Kafka 集群相关信息，Zookeeper 集群一旦先停止，Kafka 集群就没有办法再获取停止进程的信息，只能手动杀死 Kafka 进程了</li></ul> <h2 id="kafka群起脚本"><a href="#kafka群起脚本" class="header-anchor">#</a> kafka群起脚本</h2> <p>设置群起脚本的前提是各个虚拟机配置了SSH免密登录</p> <p>// todo xxx ssh</p> <h3 id="写法1"><a href="#写法1" class="header-anchor">#</a> 写法1</h3> <p>在/opt/module/bin 目录下创建kkstart.sh</p> <div class="language-bash line-numbers-mode"><pre class="language-bash"><code><span class="token shebang important">#!/bin/bash</span>
<span class="token keyword">for</span> <span class="token for-or-select variable">i</span> <span class="token keyword">in</span> linux101 linux102 linux103
<span class="token keyword">do</span>
        <span class="token builtin class-name">echo</span> <span class="token string">&quot;================           <span class="token variable">$i</span>             ================&quot;</span>
        <span class="token function">ssh</span> <span class="token variable">$i</span> <span class="token string">'/opt/module/kafka/bin/kafka-server-start.sh -daemon /opt/module/kafka/config/server.properties'</span>
<span class="token keyword">done</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br></div></div><p>在/opt/module/bin 目录下创建kkstart.sh</p> <div class="language-bash line-numbers-mode"><pre class="language-bash"><code><span class="token shebang important">#!/bin/bash</span>
<span class="token keyword">for</span> <span class="token for-or-select variable">i</span> <span class="token keyword">in</span> linux101 linux102 linux103
<span class="token keyword">do</span>
        <span class="token builtin class-name">echo</span> <span class="token string">&quot;================           <span class="token variable">$i</span>             ================&quot;</span>
        <span class="token function">ssh</span> <span class="token variable">$i</span> <span class="token string">'/opt/module/kafka/bin/kafka-server-stop.sh /opt/module/kafka/config/server.properties'</span>
<span class="token keyword">done</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br></div></div><p>设置权限</p> <div class="language-bash line-numbers-mode"><pre class="language-bash"><code><span class="token function">chmod</span> +x kkstart.sh 
<span class="token function">chmod</span> +x kkstop.sh
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br></div></div><h3 id="写法2"><a href="#写法2" class="header-anchor">#</a> 写法2</h3> <p>在/opt/module/bin 目录下创建文件 kf.sh 脚本文件</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 bin<span class="token punctuation">]</span>$ <span class="token function">vim</span> kf.sh
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>内容如下</p> <div class="language-bash line-numbers-mode"><pre class="language-bash"><code><span class="token shebang important">#!/bin/bash</span>

<span class="token keyword">case</span> <span class="token variable">$1</span> <span class="token keyword">in</span>
<span class="token string">&quot;start&quot;</span><span class="token punctuation">)</span><span class="token punctuation">{</span>
	<span class="token keyword">for</span> <span class="token for-or-select variable">i</span> <span class="token keyword">in</span> linux101 linux102 linux103
    <span class="token keyword">do</span>
    	<span class="token builtin class-name">echo</span> <span class="token string">&quot; --------启动 <span class="token variable">$i</span> Kafka-------&quot;</span>
        <span class="token function">ssh</span> <span class="token variable">$i</span> <span class="token string">&quot;/opt/module/kafka/bin/kafka-server-start.sh -daemon /opt/module/kafka/config/server.properties &quot;</span>
    <span class="token keyword">done</span>
<span class="token punctuation">}</span><span class="token punctuation">;</span><span class="token punctuation">;</span>
<span class="token string">&quot;stop&quot;</span><span class="token punctuation">)</span><span class="token punctuation">{</span>
	<span class="token keyword">for</span> <span class="token for-or-select variable">i</span> <span class="token keyword">in</span> linux101 linux102 linux103
    <span class="token keyword">do</span>
    	<span class="token builtin class-name">echo</span> <span class="token string">&quot; --------停止 <span class="token variable">$i</span> Kafka-------&quot;</span>
        <span class="token function">ssh</span> <span class="token variable">$i</span> <span class="token string">&quot;/opt/module/kafka/bin/kafka-server-stop.sh&quot;</span>
    <span class="token keyword">done</span>
<span class="token punctuation">}</span><span class="token punctuation">;</span><span class="token punctuation">;</span>
<span class="token keyword">esac</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br><span class="line-number">17</span><br><span class="line-number">18</span><br></div></div><p>添加执行权限</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 bin<span class="token punctuation">]</span>$ <span class="token function">chmod</span> +x kf.sh
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>启动集群命令</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 ~<span class="token punctuation">]</span>$ kf.sh start
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>停止集群命令</p> <div class="language-sh line-numbers-mode"><pre class="language-sh"><code><span class="token punctuation">[</span>root@linux101 ~<span class="token punctuation">]</span>$ kf.sh stop
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div></div></div>  <div class="page-edit"><!----> <!----> <div class="last-updated"><span class="prefix">Last Updated:</span> <span class="time">2022/05/22, 12:42:00</span></div></div> <div class="page-nav-wapper"><div class="page-nav-centre-wrap"><a href="/pages/b70965/" class="page-nav-centre page-nav-centre-prev"><div class="tooltip">概述</div></a> <a href="/pages/22aea2/" class="page-nav-centre page-nav-centre-next"><div class="tooltip">命令操作</div></a></div> <div class="page-nav"><p class="inner"><span class="prev">
        ←
        <a href="/pages/b70965/" class="prev">概述</a></span> <span class="next"><a href="/pages/22aea2/">命令操作</a>→
      </span></p></div></div></div> <!----></main></div> <div class="footer"><div class="icons"><a href="mailto:work_stt@163.com" title="email" target="_blank" class="iconfont icon-youjian"></a><a href="https://github.com/shetengteng" title="GitHub" target="_blank" class="iconfont icon-github"></a></div> 
  Theme by
  <a href="https://github.com/xugaoyi/vuepress-theme-vdoing" target="_blank" title="本站主题">Vdoing</a> 
    | Copyright © 2021-2022
    <span>Shetengteng | MIT License</span></div> <div class="buttons"><div title="返回顶部" class="button blur go-to-top iconfont icon-fanhuidingbu" style="display:none;"></div> <div title="去评论" class="button blur go-to-comment iconfont icon-pinglun" style="display:none;"></div> <div title="主题模式" class="button blur theme-mode-but iconfont icon-zhuti"><ul class="select-box" style="display:none;"><li class="iconfont icon-zidong">
          跟随系统
        </li><li class="iconfont icon-rijianmoshi">
          浅色模式
        </li><li class="iconfont icon-yejianmoshi">
          深色模式
        </li><li class="iconfont icon-yuedu">
          阅读模式
        </li></ul></div></div> <!----> <!----> <!----></div><div class="global-ui"><div></div></div></div>
    <script src="/assets/js/app.ab6a7ec7.js" defer></script><script src="/assets/js/2.bc9beebf.js" defer></script><script src="/assets/js/219.318a1817.js" defer></script>
  </body>
</html>
